Written by Dare O. on 2022-05-26

Configuring a DFX project to use React

Introduction

IC (Internet computer) is a blockchain that enables developers, organizations and entrepreneurs to build and deploy secure autonomous canisters otherwise known as smart contracts. To a dapp developer, IC provides the features such as:

  • Globally accessible, public blockchain to help run smart contracts at web speed and very interactive web content to users.

  • Secure cryptographic protocols that guarantees secure executions of smart contracts.

  • A network of blockchains connected using chain key cryptography with great scalability.

To develop and deploy dapp projects to the internet computer, you would need to install the difinity canister SDK also known as DFX. Below are the steps to help successfully configure your development environment as well as configurations to use React on an ubuntu machine.

Step 1: Installing SDK

To install the difinty canister SDK, also known as "dfx" copy-paste the command below into your terminal and hit enter.

DFX_VERSION=0.9.3 sh -ci "$(curl -fsSL https://sdk.dfinity.org/install.sh)"

Depending on the version of dfx you are using, you can change the version number. To confirm the installation was successful, the output of the command below should be a version number of dfx installed.

dfx --version

Installing code editor

To design and develop dfx project you would need a source code editor. A famous and user-friendly source code editor is a visual studio code. Depending on your distribution, you can find the right command to install VScode on your machine here.

Installing Node

DFX requires node version 16 or higher so the application works properly. To install node on your machine, please see the installation process here. Once the installation is complete, you can confirm the installation is successful, the output of the command below should be the node version you have installed.

node --version

Step 2: Create dfx project

To create a default/template dfx project run the command below. Where "project-name" is the name of your project.

dfx new {project name}

Open a new VSCode window and open the newly created project to edit the project settings.

Rename index.js

Expand the dir {"project name"_assets} and rename the index.js file to "index.jsx". Depending on your file structure, you can create your components and frontend dir in the src dir.

Edit webpack.config

In the web-pack config file, find the "module.exports" block, in the "entry" object change the .js option to ".jsx". Example below

 entry: {
      // The frontend.entrypoint points to the HTML file for this build, so we need
      // to replace the extension to `.js`.
      index: path.join(__dirname, asset_entry).replace(/\.html$/, ".jsx"),
   },

Scroll down to the file and uncomment the module loaders block. Example below.

   // Depending in the language or framework you are using for
   // front-end development, add module loaders to the default
   // webpack configuration. For example, if you are using React
   // modules and CSS as described in the "Adding a stylesheet"
   // tutorial, uncomment the following lines:
   module: {
      rules: [
         { test: /\.(ts|tsx|jsx)$/, loader: "ts-loader" },
         { test: /\.css$/, use: ["style-loader", "css-loader"] },
      ],
   },

Create tsconfig.json file

On the root level of your project dir, create a file named "tsconfig.json" and enter the code below in the file.

   {
  "compilerOptions": {
    "target": "es2018",        /*Specify ECMAScript target version: 'ES3' (default), 'ES5', 'ES2015', 'ES2016', 'ES2017', 'ES2018', 'ES2019' or 'ESNEXT'.*/
    "lib": ["ES2018", "DOM"],  /*Specify library files to be included in the compilation.*/
    "allowJs": true,           /*Allow javascript files to be compiled.*/
    "jsx": "react",            /*Specify JSX code generation: 'preserve', 'react-native', or 'react'.*/
  },
  "include": ["src/**/*"],
}

Step 3: Starting dfx project

Once the configuration is done, the next step is to start the project so you can interact with your application.

Start canister

dfx start --emulator

Expose your actor

To expose your actor(s) to your app.jsx or index.jsx file, run the command below. Where "canister name" is your project name.

dfx generate {Canister Name}

Install npm packages

npm install

Deploy canister

dfx deploy

Start frontend

To start your react app, run the command below

npm start

Once the application starts, you can view it on your local browser via URL: http://localhost:8080/